<!-- subpkg_consult/room/components/rate-info.vue -->
<script lang="ts" setup>
  import { evaluateDoctorApi } from '@/apis/room'
  import { computed, ref } from 'vue'

  const formData = ref({
    score: 0,
    content: '',
    anonymousFlag: 0,
  })

  // 统计字数
  const wordCount = computed(() => {
    return formData.value.content.length
  })
  // 是否允许提交
  const buttonEnabled = computed(() => {
    return formData.value.score
  })
  // 是否匿名提交
  function onAnonymousClick() {
    formData.value.anonymousFlag = Math.abs(formData.value.anonymousFlag - 1)
  }

  const props = defineProps<{
    orderId: string
    doctorId: string
    type?: number
  }>()
  // 是否已经评价
  // alert(props.type)
  // 提交评价
  async function onFormSubmit() {
    // 提交评价
    await evaluateDoctorApi({
      docId: props.doctorId,
      orderId: props.orderId,
      ...formData.value,
    })
    uni.showToast({
      title: '感谢您的评价',
    })
  }

</script>
<template>
  <!-- 医生评价 -->
  <view class="doctor-rating">
    <view class="title">医生服务评价</view>
    <view class="subtitle">本次在线问诊服务您还满意吗？</view>
    <view class="rating">
      <uni-rate
        v-model="formData.score"
        :readonly="type === 24"
        :size="28"
        margin="12"
        :value="0"
      />
    </view>
    <template v-if="type !== 24">
      <view class="text">
        <uni-easyinput
          type="textarea"
          :maxlength="150"
          v-model="formData.content"
          :input-border="false"
          :style="{ backgroundColor: '#f6f6f6' }"
          placeholder-style="font-size: 28rpx; color: #979797"
          placeholder="请描述您对医生的评价或是在医生看诊过程中遇到的问题"
        />
        <text class="word-count">{{ wordCount }}/150</text>
      </view>
      <view @click="onAnonymousClick" class="anonymous">
        <uni-icons v-if="formData.anonymousFlag" size="16" color="#16C2A3" type="checkbox-filled" />
        <uni-icons v-else size="16" color="#d1d1d1" type="circle" />
        <text class="label">匿名评价</text>
      </view>
      <button :disabled="formData.anonymousFlag === 0" @click="onFormSubmit" class="uni-button">
        提交
      </button>
    </template>
  </view>
</template>

<style lang="scss">
  .doctor-rating {
    padding: 30rpx 30rpx 40rpx;
    border-radius: 20rpx;
    background-color: #fff;
    margin-top: 60rpx;

    .title {
      text-align: center;
      font-size: 30rpx;
      color: #121826;
    }

    .subtitle {
      text-align: center;
      font-size: 24rpx;
      color: #6f6f6f;
      margin: 10rpx 0 20rpx;
    }

    .rating {
      display: flex;
      justify-content: center;
    }

    .text {
      padding: 20rpx 30rpx;
      margin-top: 20rpx;
      background-color: #f6f6f6;
      border-radius: 20rpx;
      position: relative;
    }

    :deep(.uni-easyinput__content-textarea) {
      font-size: 28rpx;
    }

    .word-count {
      position: absolute;
      bottom: 20rpx;
      right: 30rpx;
      line-height: 1;
      font-size: 24rpx;
      color: #6f6f6f;
    }

    .anonymous {
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 30rpx 0;
      color: #6f6f6f;
      font-size: 24rpx;

      .label {
        margin-left: 6rpx;
      }
    }

    .uni-button[disabled] {
      color: #a6dbd5;
      background-color: #eaf8f6;
    }
  }
</style>
